package com.he.algorithm.order;

import java.util.Arrays;

/**
 * @description: 插入排序
 * @Author: HCL
 * @Date: 2024/9/3 9:55
 */
public class InsertSort {

    public static void sort(int[] nums) {
        for (int i = 1; i < nums.length; i++) {
            int key = nums[i];// 选取当前要插入的元素
            int j = i - 1;// 从前一个元素开始比较
            // 将比key大的元素向后移动一位
            while (j >= 0 && nums[j] > key) {
                nums[j + 1] = nums[j];
                j--;
            }
            nums[j + 1] = key;// 找到插入位置，插入key
        }
    }

    public static void main(String[] args) {
        int[] nums = {7, 1, 3, 9, 5, 2, 6};
        sort(nums);
        System.out.println(Arrays.toString(nums));
    }
}
